package com.huike.web.controller.review;


import com.huike.common.core.controller.BaseController;
import com.huike.common.core.domain.AjaxResult;
import com.huike.common.core.page.TableDataInfo;
import com.huike.common.exception.CustomException;
import com.huike.review.pojo.Review;
import com.huike.review.service.ReviewService;
import com.huike.review.vo.MybatisReviewVO;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import java.util.List;

/**
 * 该Controller主要是为了复习三层架构以及Mybatis使用的，该部分接口已经放开权限，可以直接访问
 * 同学们在此处编写接口通过浏览器访问看是否能完成最简单的增删改查
 */
@Slf4j
@RestController
@RequestMapping("/review")
public class MybatisReviewController extends BaseController {

    @Autowired
    private ReviewService reviewService;

    /**=========================================================新增数据============================================*/
    @GetMapping("/saveData/{name}/{age}/{sex}")
    public AjaxResult saveData(@PathVariable String name, @PathVariable Integer age,@PathVariable String sex){

        try {
            reviewService.save(name,age,sex);
        }catch (Exception e){
            throw new CustomException("添加失败");
        }
        return AjaxResult.success("添加成功");
    }
    @PostMapping("/saveData")
    public AjaxResult saves(@RequestBody Review vo){
     reviewService.saves(vo);
      return AjaxResult.success("添加成功");
    }
    /**=========================================================删除数据=============================================*/
    @DeleteMapping("remove/{id}")
    public AjaxResult delete(@PathVariable Long id){
        reviewService.delete(id);
        return AjaxResult.success("删除成功");
    }
    /**=========================================================修改数据=============================================*/
    @PostMapping("/update")
    public AjaxResult update(@RequestBody Review review){
        reviewService.update(review);
        return AjaxResult.success("修改成功");
    }
    /**=========================================================查询数据=============================================*/
    @GetMapping("/getById")
    public AjaxResult getById(@RequestParam Integer id){
      Review review=reviewService.getById(id);
    return AjaxResult.success(review);
    }
    @GetMapping("/getDataByPage")
    public TableDataInfo page(@RequestParam(defaultValue = "1") Integer pageNum,@RequestParam(defaultValue = "10") int pageSize){
        startPage();
        List<Review> list = reviewService.getDataByPage();
        return getDataTable(list);
    }
}